草庐IT

java - 找不到 studio.sh 命令 - Ubuntu

全部标签

testing - 在 init 函数中使用相对路径在测试中找不到

在单元测试无法找到的init函数中使用相对路径时,我遇到了一个烦人的问题。假设我有一个结构如下的项目:.├──conf│  └──blacklist├──filter│  ├──filter.go│  └──filter_test.go并且在filter.go的init函数中,我尝试使用相对路径conf/blacklist加载黑名单,避免加载它多次。由于默认工作目录恰好是项目根目录,因此它适用于编译后的二进制文件。然而filter_test.go会panicpanic:openconf/blacklist:nosuchfileordirectory,因为gotest总是使用包目录作为工

go - 如何从 Visual Studio Code 中的包覆盖范围中排除生成的模拟

我正在通过VisualStudioCode对Golang项目进行单元测试,我使用的依赖项之一称为mockery.它通过在找到的包中创建目标Golang接口(interface)的模拟来工作。因此,即使我发誓要测试所述包中的所有内容,我的测试覆盖率也只有58%。然而,当我从包中取出模拟(事实证明我不需要它)时,我的测试覆盖率肯定像雨一样猛增到我预期的97.9%。有什么方法可以告诉VisualStudioCode“嘿,不要在包覆盖率计算中包含模拟模拟(以mock_开头)”? 最佳答案 解决方案是使用mockery-inpkg和-test

visual-studio - 如何使用 VSCode 在 GOARCH=386 的 64 位 GO 项目上使用 32 位 DLL

我已经使用默认包安装了VSCode和GO扩展。我的项目需要加载一个32位DLL。当我使用F5启动项目时,我在syscall.LoadLibrary()上收到错误193。我在互联网上发现,当有人试图在64位arch上加载32位DLL时,通常会发生错误。我认为如果我使用GOARCH=386进行调试,我将能够加载DLL。但每次我尝试使用GOARCH=386执行时,我都会在VSCode上收到错误消息,提示该架构不受支持。需要帮助。 最佳答案 (我假设64位DLL是遥不可及的)64位进程无法将32位模块加载到其进程空间,32位进程也无法将64

docker - 通过 'revel build <testapp>' 的 run.sh 二进制文件未在 docker 容器内运行

因为我最近开始使用revel框架来构建goweb应用程序。我创建了一个测试应用程序(orpat),将其编译为“revelbuildorpatprod”并更改了confPORT->8084以发布该应用程序。生成的文件是-orpat(可执行文件11MB)运行.sh运行.bat源/文件夹它从其他位置在我的本地系统上执行良好(当然它安装了golang和revel)。http://localhost:8084我将构建文件复制到未安装golang的虚拟机中,它也在那里执行'./run.sh':在终端中运行此cmd足以使应用联机。下面是dockerfile->FROMgolang:1.10.4-al

go - 如何使用 golang 运行 dir 命令?

这是我的代码:packagemainimport("bytes""fmt""io""os/exec")funcrunCommand(commandstring)io.Writer{cmdName:="cmd.exe"cmdArgs:=[]string{"/c",command}fmt.Println("Runningcommand:"+command)cmd:=exec.Command(cmdName,cmdArgs...)varoutbytes.Buffervarstderrbytes.Buffercmd.Stdout=&outcmd.Stderr=&stderrcmd.Run()r

go - 管道多个命令然后写入文件

我正在尝试通过管道传输多个*exec.Cmd,然后写入文件。当我尝试使用一个cmd并输出到文件时,它会写入文件。但是,当我尝试使用多个命令并输出到文件时,它没有。但是exec.Cmd似乎正在管道化,因为它可以正确地输出。outfile,err:=os.Create("./out.txt")iferr!=nil{panic(err)}deferoutfile.Close()c1:=exec.Command("sh","-c","whilesleep1;doechotest;done")c1.Stdout=outfile_=c1.Run()for{}上面的代码每隔一秒写入一次文件。但是当我

go - 如何让每个眼镜蛇命令解析自己的标志?获取初始化循环(预期,但如何避免?)

我正在按照https://github.com/spf13/cobra#flags上的指南进行操作,但我对那里的一些内容感到困惑。我有一些服务(restapi、电子邮件服务、事件),我正在尝试做这样的事情:gorun*.gorest-envDEV-p3000gorun*.goevents-envDEV-p3001我正在关注github页面,所以我定义了我的rootCmd和restCmd:varrootCmd=&cobra.Command{Use:"myappname",}varrestCmd=&cobra.Command{Use:"rest",Short:"RESTAPI",Long:

当找不到值时,Gorm 返回空对象而不是默认对象

我在一个小go应用程序中使用GORM进行了MySQL查询。我已经声明了我的域结构typeDomainstruct{gorm.ModelNamestring...}然后,当我使用此方法使用GORM向MySQL发送查询时。funcDomainInfos(whttp.ResponseWriter,r*http.Request){vars:=mux.Vars(r)w.WriteHeader(http.StatusOK)vardDomainconfig.DbConnection.Where("name=?",vars["domain"]).Find(&d)json.NewEncoder(w).E

go - 使用 os/exec 命令从 Windows 交叉编译到 Linux

标题基本上就是这么说的。我知道我能做到setGOOS=linuxsetGOARCH=amd64在gobuild之前在cmd中,但我正在尝试编写一个构建脚本并使用exec.Command完成所有操作。我的gobuild-oetc与exec.Command(它构建)一起工作,但是在执行以下任一命令后在测试脚本中打印GOOS时:cmd:=exec.Command("set","GOOS=linux")//ORcmd:=exec.Command("setGOOS=linux")我得到了windows。有什么想法吗?谢谢! 最佳答案 我强烈建

go - 在 Ubuntu Precise 上安装 snap

购买ARK-20-S8A11E后,我发现它只支持ubuntu12.04,并且网络管理器使用snap,它只在ubuntu14上可用。我需要Mobilemanager来收集PC中集成的LTE模块的信息。为此,我尝试从源代码安装snap。我需要“go”,并且使用apt-getinstallgolang,精确安装的最后一个版本是go1。snap使用go1.6以上版本。因此,我从源代码安装了最新版本的go。安装好,go--version的输出是:goversiongo1.11.4linux/amd,并测试了一个basidhello.go。我点击此链接进行快照安装:https://github.c